What is Claimed is : 

r>--n 1 . A method of providing multiple but exclusive relationships between 
tables in a relational database, comprising: 

\ selectively associating a foreign key associated with a record in a relating table 
with aspecific one of a plurality of related tables based on at least one attribute of the 
record in the relating table. 

2\ The method of Claim 1 , wherein the relating table comprises a first 
table and me related tables comprise a plurality of second tables, and wherein the step 
of selectively associating comprises the steps of: 

defining a foreign key of records of the first table; 

definmg a plurality of types of foreign key associations, each of the types 
corresponding to a respective one of the plurality of second tables; 

selecting one of the second tables having a type corresponding to a type value 
associated with^ record of the first table; and 

identifying a record in the selected second table based on a foreign key value 
of the foreign kej\of the record in the first table. 

3. The method of Claim 1, wherein the relating table comprises an entity 
table and the plurality of related tables comprise entity tables such that the foreign key 
and the at least one atuibute provide a one-to-many relationship between the relating 
entity table and a corresponding one of the related entity tables. 

4. The method of Claim 3, wherein the step of selectively associating 
comprises defining a database trigger to enforce relationships between the types of 
foreign key associations anci the corresponding particular one of the plurality of 
related tables. \ 

5. The method of Claim 3, wherein the step of selectively associating 
comprises the steps of: \ 

defining a type associatedWith respective ones of the plurality of related tables 
in a type table; \ 
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accessing the t>^e table to determine a type associated with a record in the 
relating table based on i value in the record in the relating table which identifies a 
record in the type table which identifies a type; and 

associating the type identified in the type table with the record in the relating 
table so as to select one Lf the plurality of related tables which contain records having 
foreign key associations Iwhich point the record in the relating table. 



6. The method of Claim 1, wherein the relating table comprises a third 
table, the related tables comprise a plurality of second tables and wherein the third 
table relates records in a firs^ entity table to records in a corresponding one of the 
second tables and wherein the step of selectively associating comprises the steps of: 

defining a foreign key\)f records of the third table; 

defining a plurality of tVpes of foreign key associations, each of the types 
corresponding to a respective one of the plurality of second tables; 

selecting one of the secoi^d tables having a type corresponding to a type value 
associated with a record of the third table; and 

identifying a record in the selected second table based on a foreign key value 
of the foreign key of the record in tl^e third table. 



7. The method of Claim 6\ wherein the third table relates records in the 
first table to records in a corresponding one of the second tables such that the foreign 
key and type provide a many-to-many relationship between the second entity table 
and the first entity table utilizing the third Velationship table. 

8. The method of Claim 7, wherein records in the third table have a type 
value which identifies one of the plurality of Wcond tables and wherein the step of 
selecting one of the second tables having a tyne corresponding to a type value 
associated with a record of the third table comArises the steps of: 

obtaining the type value of a record of the third table; and 
selecting one of the second tables corresponding to the type value from the 
record of the third table. 

9. The method of Claim 8, wherein th^ step of obtaining the type value 
comprises joining the first table and the third table auch that the type value associated 
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with records in the first table is implicitly specified by the corresponding records in 
the third table. * 



10. The method of Claim 7, wherein the step of defining a plurality of 
types of foreign key associations comprises defining a plurality of types of foreign 
key associations in a type table; and 

wherein the step of selecting one of the second tables comprises accessing the 
type table to determine a type of foreign key association associated with a record in 
the third table based on a value in the record in the third table which identifies a 
record in the type table which identifies a type of foreign key association. 



1 1 . The method of Claim 8*^ wherein the step of defining a plurality of 
types of foreign key associations comprises defining a plurality of types of foreign 
key associations in a type table; and \ 

wherein the step of selecting one of the second tables corresponding to the 
type value from the record of the third table further comprises accessing the type table 
to determine a type of foreign key association associated with a record in the third 
table based on a value in the record in thelthird table which identifies a record in the 
type table which identifies a type of foreigji key association. 



12. A database system for providing multiple but exclusive relationships 
between tables in a relational database, comiDrising: 
a relating table; 

a plurality of related tables; and 

means for selectively associating a foreign key value of a record in the relating 
table with a specific one of the plurality of related tables based on at least one 
attribute of the record containing the foreign keyiin the relating table. 



13. The database system of Claim 12, A^herein the relating table comprises 
a first table and the related tables comprise a plurality of second tables, and wherein 



the means for selectively associating comprises 

means for defining a foreign key of records ot the first table; 
means for defining a plurality of types of foreign key associations, each of the 

types corresponding to a respective one of the pluralitjj of second tables; 
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means for selecting*bne of the second tables having a type corresponding to a 
type value associated with alrecord of the first table; and 

identifying a record in the selected second table based on a foreign key value 
of the foreign key of the record in the first table. 



14. The database system of Claim 12, wherein the relating table comprises 
an entity table and the plurality of related tables comprise entity tables such that the 
foreign key and the at least oi^e attribute provide a one-to-many relationship between 
the relating entity table and a corresponding one of the related entity tables. 



15. The database system of Claim 14, wherein the means for selectively 
associating comprises means fondefining a database trigger to enforce relationships 
between the types of foreign key ^associations and the corresponding particular one of 
the plurality of related tables. 



16. The database system of Claim 14, wherein the means for selectively 
associating comprises: ^ 

means for defining a type associated with respective ones of the plurality of 
related tables in a type table; 

means for accessing the type tkble to determine a type associated with a record 
in the relating table based on a value in the record in the relating table which identifies 
a record in the type table which identifies a type; and 

means for associating the type icltntified in the type table with the record in 
the relating table so as to select one of the plurality of related tables which contain 
records having foreign key associations which point the record in the relating table. 

1 7. The database system of Claim 12, wherein the relating table comprises 
a third table, the related tables comprise a pBurality of second tables and wherein the 
third table relates records in a first entity table to records in a corresponding one of the 
second tables and wherein the means for selectively associating comprises: 

means for defining a foreign key of records of the third table; 
means for defining a plurality of types of foreign key associations, each of the 
types corresponding to a respective one of the plurality of second tables; 
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means for selecting one of the second tables having a type corresponding to a 
type value associated with a record ofithe third table; and 

means for identifying a recordlin the selected second table based on a foreign 
key value of the foreign key of the record in the third table. 



1 8. The database system 
records in the first table to records in a 
that the foreign key and type provide a 
second entity table and the first entity 



ofl Claim 17, wherein the third table relates 
corresponding one of the second tables such 
many-to-many relationship between the 
ble utilizing the third relationship table. 



19. The database system of Qlaim 18, wherein the means for selectively 
associating comprises means for definina a database trigger to enforce relationships 
between the types of foreign key associatipns and the corresponding particular one of 
the plurality of related tables. 

20. The database system of ClaiVn 1 8, wherein records in the third table 
have a type value which identifies one of the plurality of second tables and wherein 
the means for selecting one of the second tables having a type corresponding to a type 
value associated with a record of the third table comprises: 

means for obtaining the type value of a record of the third table; and 
means for selecting one of the second rubles corresponding to the type value 
from the record of the third table. 

2 1 . The database system of Claim 20\ wherein the means for obtaining the 
type value comprises means for joining the first mble and the third table such that the 
type value associated with records in the first tabljp is implicitly specified by the 
corresponding records in the third table. 



22. The database system of Claim 20, A^.herein the means for defming a 
plurality of types of foreign key associations comprises means for defining a plurality 
of types of foreign key associations in a type table; iid 

wherein the means for selecting one of the sefcond tables comprises means for 
accessing the type table to determine a type of foreign key association associated with 
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a record in the third table based on a value in the record in the third table which 
identifies a record in the type table which identifies a type of foreign key association. 



23. The database system of Claim 2(^/ wherein the means for defining a 
plurality of types of foreign key associations emprises means for defining a plurality 
of types of foreign key associations in a type table; and 

wherein the means for selecting one Jfthe second tables corresponding to the 
type value fi-om the record of the third table/further comprises means for accessing the 
type table to determine a type of foreign key association associated with a record in 
the third table based on a value in the record in the third table which identifies a 
record in the type table which identifies a |ype of foreign key association. 

24. A computer program product for providing multiple but exclusive 
relationships between tables in a relational database, comprising: 

a computer readable medium ha^^ng computer readable program code 
embodied therein, the computer readable program code comprising: 

computer readable program code configured to selectively associate a foreign 
key associated with a record in a relating table with a specific one of a plurality of 
related tables based on at least one attribute of the record in the relating table. 



25. The computer program Product of Claim 24, wherein the relating table 
comprises a first table and the related t ibles comprise a plurality of second tables, and 
wherein the computer readable prograri code configured to selectively associate 
comprises: 

computer readable program coc e configured to define a foreign key of records 
of the first table; 

computer readable program code configured to define a plurality of types of 
foreign key associations, each of the tj pes corresponding to a respective one of the 
plurality of second tables; 

computer readable program code configured to select one of the second tables 
having a type corresponding to a type value associated with a record of the first table; 
and 1 
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computer readable program code configured to identify la record in the 
selected second table based on a foreign key value of the foreign key of the record in 
the first table. / 



26. The computer program product of Claim 24, wherein the relating table 
comprises an entity table and the plurality of related tabl^^ comprise entity tables such 
that the foreign key and the at least one attribute provide a one-to-many relationship 
between the relating entity table and a corresponding oiie of the related entity tables. 



27. The computer program product of Claim 26, wherein the computer 
readable program code configured to selectively associate comprises computer 
readable program code configured to define a database trigger to enforce relationships 
between the types of foreign key associations and the corresponding particular one of 
the plurality of related tables. 



28. The computer program product? of Claim 26, wherein the computer 
readable program code configured to selectively associate comprises: 

computer readable program code configured to define a type associated with 
respective ones of the plurality of related tables in a type table; 

computer readable program code configured to access the type table to 
determine a type associated with a recorcyin the relating table based on a value in the 
record in the relating table which identifies a record in the type table which identifies 
a type; and 

computer readable program cofle configured to associate the type identified in 
the type table with the record in the relating table so as to select one of the plurality of 
related tables which contain records^aving foreign key associations which point the 
record in the relating table. 

29. The computer program product of Claim 24, wherein the relating table 
comprises a third table, the related tables comprise a plurality of second tables and 
wherein the third table relates records in a first entity table to records in a 
corresponding one of the seconn tables and wherein the computer readable program 
code configured to selectively associate comprises: 



computer readable program code configured to define a foreign key of records 
of the third table; . 

computer readable program code configured to Refine a plurality of types of 
foreign key associations, each of the types corresponding to a respective one of the 
5 plurality of second tables; 

computer readable program code configured^to select one of the second tables 
having a type corresponding to a type value associated with a record of the third table; 
and I 

computer readable program code configured to identify a record in the 
1 0 selected second table based on a foreign key v^ue of the foreign key of the record in 
the third table. 
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30. The computer program product of Claim 29, wherein the third table 
relates records in the first table to records in a corresponding one of the second tables 
such that the foreign key and type provide p. many-to-many relationship between the 
second entity table and the first entity tabl-e utilizing the third relationship table. 
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3 1 , The computer program product of Claim 30, wherein the computer 
readable program code configured to selectively associates comprises computer 
20 readable program code that defines a aatabase trigger to enforce relationships between 
the types of foreign key associations and the corresponding particular one of the 
plurality of related tables. 



32. The computer progckm product of Claim 30, wherein records in the 
25 third table have a type value whicn identifies one of the plurality of second tables and 
wherein the computer readable program code configured to select one of the second 
tables having a type correspondipg to a type value associated with a record of the 
third table comprises: 

computer readable pro-am code configured to obtain the type value of a 
30 record of the third table; and 

computer readable proferam code configured to select one of the second tables 



corresponding to the type val 



le fi-om the record of the third table. 
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33. The computer program product of Claim 32, wherein the cJomputer 
readable program code configured to obtain the type value comprises/X)mputer 
readable program code configured to join the first table and the tlura table such that 
the type value associated with records in the first table is implj^tly specified by the 
corresponding records in the third table. 

34. The computer program product of Ckcfm 3 1 , wherein the computer 
readable program code configured to define a plui^Uty of types of foreign key 
associations comprises computer readable program code configured to define a 
plurality of types of foreign key associations4n a type table; and 

wherein the computer readable program code configured to select one of the 
second tables comprises computer readable program code configured to access the 
type table to determine a type of forei^ key association associated with a record in 
the third table based on a value in the record in the third table which identifies a 
record in the type table which identifies a type of foreign key association. 

35. The computer program product of Claim 32, wherein the computer 
readable program code configured to define a plurality of types of foreign key 
associations comprises computer readable program code configured to define a 
plurality of types of foreim key associations in a type table; and 

wherein the computer readable program code configured to select one of the 
second tables corresponding to the type value firom the record of the third table further 
comprises computer readable program code configured to access the type table to 
determine a type of foreign key association associated with a record in the third table 
based on a value in ttie record in the third table which identifies a record in the type 
table which identifies a type of foreign key association. 



36. Amu 
first table and a plijrality 

associating 

associating 
in the first table id 
tables the record is 



thod of enforcing a multiple but exclusive relationship between a 
of second tables, comprising: 
a type with respective ones of the plurality of second tables; 
a type with records in the first table such that the type of a record 
ntifies which of the respective ones of the plurality of second 
associated with; and 



24 




enforcing the multiple but exclusive relationship between records in the 
second tables and the first table based on the type associated with a record in the first 
table. 

37. The method of Claim 36, whereiiVthe step of enforcing the multiple 
but exclusive relationship comprises the step o» assuring that each record in each of 
the plurality of second tables has an associatecy foreign key which only points to 
records in the first table which have a type as^ciated with the corresponding one of 
the plurality of second tables. 

38. The method of Claim 36, wh^ein the step of enforcing the relationship 
comprises the step of preventing entry of a record in one of the plurality of second 
tables which points to a record in the first table having a type other than a type 
associated with the one of the plurality of sjecond tables. 

39. The method of Claim 36, Wherein the type associated with the record 
in the first table is associated by providing a type table of types and accessing the type 
table based on attributes of the record in fhe first table so as to ascertain the type 
associated with the record. 



40. A system for enforcing i multiple but exclusive relationship between a 
first table and a plurality of second tables, comprising: 

means for associating a type with respective ones of the plurality of second 
tables; / 

means for associating a type ^vith records in the first table such that the type of 
a record in the first table identifies wliich of the respective ones of the plurality of 
second tables the record is associated with; and 

means for enforcing the mult pie but exclusive relationship between records in 
the second tables and the first table based on the type associated with a record in the 
first table. 



41. The system of Claim 4fi), wherein the means for enforcing the multiple 
but exclusive relationship comprises means for assuring that each record in each of 
the plurality of second tables has an associated foreign key which only points to 
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records in the first table which have a type associated with the corresponding one of 
the plurahty of second tables. / 



42. The system of Claim 40, wherein the means for enforcing the multiple 
but exclusive relationship comprises means for preventing entry of a record in one of 
the plurality of second tables which points to a record in the first table having a type 
other than a type associated with the one of the murality of second tables. 

43. The system of Claim 40, wherdin the means for enforcing the multiple 
but exclusive relationship comprises means for defining a database trigger which 
enforces the multiple but exclusive relation^ip. 

44. The system of Claim 40, wherein the type associated with the record in 
the first table is associated by providing a type table of types and accessing the type 
table based on attributes of the record in/the first table so as to ascertain the type 
associated with the record. 



45. A computer program product for enforcing a multiple but exclusive 
relationship between a first table and/a plurality of second tables, comprising: 

a computer readable storage medium having computer readable program code 
embodied therein, the computer readable program code comprising: 

computer readable program /code configured to associate a type with 
respective ones of the plurality of second tables; 

computer readable progranl code configured to associate a type with records in 
the first table such that the type ofja record in the first table identifies which of the 
respective ones of the plurality of feecond tables the record is associated with; and 

computer readable program code configured to enforce the multiple but 
exclusive relationship between records in the second tables and the first table based 
on the type associated with a recc rd in the first table. 



program 



46. The computer 
readable program code configured 
comprises computer readable 
each of the plurality of second ta 



product of Claim 45, wherein the computer 
to enforce the multiple but exclusive relationship 
code configured to assure that each record in 
?les has an associated foreign key which only points 
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to records in the first table which have a type associated with the corresponding one 
of the plurality of second tables. 



47. The computer program produpt of Claim 45, wherein the computer 
readable program code configured to enforce the multiple but exclusive relationship 
comprises computer readable program code configured to prevent entry of a record in 
one of the plurality of second tables which points to a record in the first table having a 
type other than a type associated with the one of the plurality of second tables. 



48. The computer program product of Claim 45, wherein the type 
associated with the record in the first table is associated by providing a type table of 
types and accessing the type table /based on attributes of the record in the first table so 
as to ascertain the type associatea with the record. 
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